& 5 



66848-002-2 




In re Application of: 



IN THE UNITED STATES PATENT AND TRADEMARK OFFICE 



PATENT 



Johan ANDERSSON et al. 



Group: Unassigned 



Serial No.: 09/973,195 



Examiner: Unassigned 



Filed: October 10, 2001 

OBJECTS IN A COMPUTER SYSTEM 



Assistant Commissioner for Patents 
Washington, D.C. 20231 



Foreign priority is hereby claimed for this application based on British patent 
application No. 0025051 .4 filed October 12, 2000. A certified copy of same is 
submitted herewith. 



DYKEMA GOSSETT PLLC 
THIRD FLOOR WEST 
1300 I Street, N. W., Ste. 300 
Washington, D.C. 20005 
(202) 522-8600 



FOREIGN PRIORITY CLAIM 



December 4, 2001 



Respectfully submitted, 




46081.1 




Patent 
Office 



C/3 





INVESTOR DJ PEOPLE 



The Patent Office 
Concept House 
Cardiff Road 
Newport 
South Wales 
NP10 8QQ 



ll, the undersigned, being an officer duly authorised in accordance with Section 74(1) and (4) 
■of the Deregulation & Contracting Out Act 1994, to sign and issue certificates on behalf of the 
Comptroller-General, hereby certify that annexed hereto is a true copy of the documents as 
Inginally filed m connection with the patent application identified therein. 



[accordance with the Patents (Companies Re-registration) Rules 1982, if a company named 
this certificate and any accompanying documents has re-registered under the Companies Act 
[ Wlth the same name 35 that with which it was registered immediately before re- 
lation save for the substitution as, or inclusion as, the last part of the name of the words 
he limited company" or their equivalents in Welsh, references to the name of the company 
hs certificate and any accompanying documents shall be treated as references to the name 
|which it is so re-registered. 

irdance with the rules, the words "public limited company" may be replaced by p I c 
IL.C. or PLC. ' '' 



jtration under the Companies Act does not constitute a new legal entity but merely 
I the company to certain additional company law rules. 



Signed 
Dated 15 October 2001 



o 








o 


o 


o 


o 


o 




iJLj 




LXJ 


OS 

O 


O 





(o|*n))liM 6Bwsm 



1 



ents Form 1/77 



Patents Act 1977 
Qel6) 



Patent 



Office 



Request for grant of a patent 

(See the notes on the back of this form. You can also get 
an explanatory leaflet from the Patent Office to help 
you fill in this form) 




The Patent Office 

Cardiff Road 
Newport 

Gwent NP9 1RH . 



AWOQ E57K03-2 D0Q06B 

4 ^mim 0.00-0025051.4 



1 . Your reference 



2. Patent application number 

(The Patent Office will fill in this part) 



1 2 OCT 2008 



0025051.4 



3 . Full name, address and postcode of the or of 

each applicant (underline all surnames) 



ABB AB 

KOPPARBERGSVAGEN 2 
SE-721 83 VASTERAS 
SWEDEN 



Patents ADP number (if you know it) 





If the applicant is a corporate body, give the 
country/state of its incorporation 


SWEDEN 




4. 


Title of the invention 


TPT 1TYTHT TT TV A A/TOT 1 T nnv TTT> 




5. 


Name of your agent (if you have one) 

"Address for service" in the United Kingdom 
to which all correspondence should be sent 

(including the postcode) 

Patents ADP number (if you know it) 


PAGE WHITE & FARRER 
54 DOUGHTY STREET 
LONDON 
WC1N 2LS 
UNITED KINGDOM 

1255003 


y 


6. 


If you are declaring priority from one or more 
earlier patent applications, give the country 
and the date of filing of the or of each of these 
earlier applications and (if you know it) the or 
each application number 


Country Priority application number 
(if you know it) 


Date of filing 
(day / month /year) 


7. 


If this application is divided or otherwise 
derived from an earlier UK application, 
give the number and the filing date of 
the earlier application 


Number of earlier application 


Date of filing 
(day / month /year) 


8. 


Is a statement of inventorship and of right 
to grant of a patent required in support of 

this request? (Answer 'Yes' if: 

a) any applicant named in part 3 is not an inventor, or 

b) there is an inventor who is not named as an 
applicant, or 

c) any named applicant is a corporate body 
See note (d)) 


YES 


Patents Form 1/77 



Patents Form 1/77 



V 




9. Enter the number of sheets for any of the 

following items you are filing with this form. 
Do not count copies of the same document 



Continuation sheets of this form 



Description 



17 



Drawing(s) 



Claim(s) 



Abstract 




10. If you are also filing any of the following, 
state how many against each item. 



Priority documents 



Translations of priority documents 

Statement of inventorship and right 
to grant of a patent (Patents Form 7/77) 

Request for preliminary examination 
and search (Patents Form 9/77) 

Request for substantive examination 
Patents Form 10/77) 



Warning 

After an application for a patent has been filed, the Comptroller of the Patent Office will consider whether publication 
or communication of the invention should be prohibited or restricted under Section 22 of the Patents Act 1977. You 
will be informed if it is necessary to prohibit or restrict your invention in this way. Furthermore, if you live in the 
United Kingdom, Section 23 of the Patents Act 1977 stops you from applying for a patent abroad without first getting 
written permission from the Patent Office unless an application has been filed at least 6 weeks beforehand in the 
United Kingdom for a patent for the same invention and either no direction prohibiting publication or 
communication has been given, or any such direction has been revoked. 

Notes 

a) If you need help to fill in this form or you have any questions, please contact the Patent Office on 0645 500505. 

b) Write your answers in capital letters using black ink or you may type them. 

c) If there is not enough space for all the relevant details on any part of this form, please continue on a separate 
sheet of paper and write "see continuation sheet" in the relevant part(s). Any continuation sheet should be 
attached to this form. 

d) If you have answered 'Yes ' Patents Form 7/77 will need to be filed. 



Any other documents 
(please specify) 



11. 



12. Name and daytime telephone number of 
person to contact in the United Kingdom 




e) Once you have filled in the form you must remember to sign and date it. 

f) For details of the fee and ways to pay please contact the Patent Office. Patents Form 1/77 



1 



Objects in a computer system 

Field of the Invention 

5 The present invention relates to objects in a computerised 

system, and in particular, but not exclusively, how to locate 
objects in a computerised system. 

Background of the Invention 

10 

In contemporary computer based systems for controlling e.g. 
manufacturing and process industries , such as chemical plants, 
oil refineries, pulp and paper mills, steel mills, automated 
factories and so on, or other control systems, such as traffic 

15 management systems, there has typically existed a large range 
of different applications of different origin that have had to 
be integrated into a single control system. Further, a control 
system may include several computers connected through a 
communication network, where said applications are distributed 

20 in different configurations for different installations. A ' 

data communication network may be a closed local network (e.g. 
a local area network LAN) , a closed global network (e.g. an 
intranet network) or an open global network (e.g. the 
Iriternet) . 

25 

Object-oriented programming languages and methods have been 
introduced to enable shorter development times of the 
computerised applications and to ease incorporation or 
integration of new applications. An aim of the object oriented 
30 techniques is to break the task down to smaller autonomous 
entities that are enabled to work together to provide the 
needed functionality. These individual entities are called 
objects. During the development of the of the set of control 
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instructions (i.e. the control software) the designer 
determines what objects are needed and the interrelations of 
each chosen object with other objects. When the control 
program is run, a functionality of the program may call an 
5 object that is stored e.g. in a database of the control 

system. An example of an object that may be need to be called 
during controlling operations of a processing plant is a 
certain pump in a certain part of the process . Examples of 
object oriented technology, without limiting to these, include 
10 technologies such as C++ or Java. 

An object may have different aspects, each aspect defining 
more precisely a characteristic and/or function of the object. 
That is, an object may associate with one or more different 

15 aspects that represent facets of the real world entity that 
the object represents. An aspect may provide a piece of the 
functionality of the object. An instance of an object 
typically refers to an object that has been instantiated to 
associate with necessary aspects. An aspect may be either 

20 exclusive or shared by several objects. An object may inherit 
an aspect from another object. 

If an object is to be called for use by a program, it needs to 
be located. That is, there has to be a way of finding the 

25 object so that the object can be called. The objects are 

typically called and located by their names, hence the term 
name -look up. To make the name look-up easier the object names 
have been conventionally arranged in a hierarchical order by 
so called directory or folder trees. The tree is arranged such 

30 that is has a main folder (root) and possible subfolders that 
are dependent from the main folder. The subf older can be found 
by indicating the name of the main folder and any possible 
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other subfolders in the tree between the main folder and the 
requested subf older . 

In a conventional tree type arrangement an object can be 
5 placed only in one directory or folder. In order to find the 
object, such as a certain pump in a plant, the search function 
has to go through the entire list or table of pumps in a given 
folder for the given plant. In addition, the search function 
needs to know the exact name or other identity of object, such 

10 as the ID number of the pump, to be able to locate it. If the 
object is placed in a subf older of a folder (which folder in 
turn may be a subf older of a folder above it) , the search 
function has to know, in addition to the exact name for the 
object, the exact look-up names for all these folder items in 

15 the path between the main (root) folder and the folder 
containing the requested object. 

Summary of the Invention 

20 Embodiments of the present invention aim to address one or 
several of the above problems. 

According to one aspect of the present invention, there is 
provided a method in an object oriented computer system, 

25 wherein objects are enabled to have relationships with each 

other, the method comprising: receiving a query for a path of 
related objects, the query including information regarding an 
object and relationships associated with the object; analysing 
the different relationships associated with objects in the 

30 system to select objects based on said information included in 
the query; and based on said analysis, selecting a path of 
related objects, one of the objects in the path being the 
object indicated by the query. 
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The path of related objects may extend between said one object 
and a root of a structure, said structure being arranged to 
organise objects relative to each other. The analysing may 
5 comprise determination of the number of relationships each 
analysed object has with other objects. An object may be 
selected based on the analysis as a starting point for further 
examination. An object with the lowest cost may be selected 
for the further examination. The cost may be determined for ^ 
10 each analysed object based on the number of relationships each 
object has with other objects. 

The query may comprise a string of name items. The string of 
name items may be arranged in subsequent tokens, one token of 
15 the string indicating a name of one object and another token 
adjacent to the one token indicating a name of another object, 
said other object being a direct or indirect child or parent 
for said one object. 

20 The further examination may comprise comparing relationships 
associated with the selected object to information in the 
query. 

The objects may be placed in different structures, the 
25 structures associating the objects with different 

relationships categories. The queried object and at least one 
other object indicated by the query may be associated with 
different structures. The objects may also have more than one 
name. The different names are indicated by aspects of the 
30 object.. An object may also be placed in more than one location 
in the structures. 
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The string of name items may comprise at least one symbol 
between the name items. The at least one symbol may be adapted 
to describe the relation between the objects the said at least 
one symbol associates with. 

The scope of the search performed in response to the query may 
be limited by information in the query. The scope of the 
search accomplished in response to the query may be limited by 
defining limitations to the search scope. Objects for the 
analysis of the relationships may be selected based on the 
information included in the query. 

According to another aspect of the present invention there is 
provided a computer program comprising program code means for 
performing any of steps of claim 1 or any claim dependent 
thereto when the program is run on a computer. The program 
code means may be stored in a computer readable medium. The 
computer program may be used for finding an object in a 
computerised control system. 

According to another aspect of the present invention there is 
provided a method in a computerised control system, 
comprising: associating objects representing real world 
entities to different relationship groups based on 
characteristics of the real world entities; initiating a 
search for an object by means of a query string containing 
information regarding the object; searching for the object 
based on a name associated with the object, relationships the 
object has with other objects and information that associates 
with relationship groups relevant for the searched object; and 
selecting a path of related objects that corresponds 
information in the query string and includes the searched 
obj ect . 
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According to another aspect of the present invention there is 
provided a data processing system comprising:, a processor 
adapted for object oriented data processing, data storage 
5 means adapted for storing data obj ects , the obj ects being 
enabled to have relationships between each other and to be 
associated with different relationship groups, wherein the 
data processing system is adapted to provide the processor 
with an indication of the location of an object in the data r r 
10 storage means based on information regarding a name associated 
with the object, relationships the object has with others of 
the objects, and the relationship groups. 

The indication may be based on a path of related objects, the 
15 object being one object on the path of related objects. The 
processor may be adapted to generate a query containing 
information regarding the object and at least one other object 
having a relationship with the object. The processor may be 
adapted to control operation of a system consisting of real 
20 world entities, the real world entities being represented by 
objects stored in the storage means. 

According to another aspect of the present invention there is 
provided a computer data signal embodied for communication in 

25 a computerised system, the communication being associated with 
location of objects in data storage means of the system, and 
the objects being enabled to have relationships between each 
another and be associated with different relationship groups, 
wherein the data signal comprises information associated with 

30 a location of an object in the data storage means based on 
information regarding a name associated with the object, 
relationships the object has with others of the objects, and 
the relationship groups. 
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The information may comprise at least one path of related 
objects, the object being one of the objects on said at least 
one path of related objects. The computer data signal may be 
5 generated at a search function of the computerised system to 
respond to a query signal, said query signal containing 
information regarding the object and at least one other object 
having a relationship with the object. The computerised system 
may be adapted to control, based on the computer data signal,,- 
10 operation of a system consisting of real world entities, the 

real world entities being represented by objects stored in the 
storage means . 

The embodiments of the invention provide a method and 
15 arrangement by means of which a search function does not 

necessarily need to know the actual look-up name of an object, 
and/or the folders in a path to the object, but the object may 
be found based on analysing contextual information. The search 
function may be made faster than what it could be if exact 
20 name information is required for the search. Some embodiments 
enable name look-up in a context where a substantially large 
number of objects exist in a computerised system. The objects 
to be located may have a number of structure links i.e. 
associations between groups of objects associated therewith. 
25 The objects may also have multiple names and be located based 
on only one of the different possible names. It may be 
possible to reduce the required system overheads that are 
required for carrying out a search. The embodiments may also 
provide a more flexible search strategy. 

30 

Brief Description of Drawings . 
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For better understanding of the present invention, reference 
will now be made by way of example to the accompanying 
drawings in which: 

Figure 1 illustrates relationships objects may have with 
other; 

Figure 2 shows objects that have been arranged in two 
structures; 

Figure 3 illustrates how objects may have relationships 
with other objects in accordance with one embodiment of the 
present invention; 

Figure 4 shows a schematic presentation of a plant and 
grouping of objects in different structures; and 

Figure 5 is a flowchart illustrating an embodiment. 



Description of Preferred Embodiments of the Invent! 



on 



The following will describe in more detail an embodiment 
wherein a >name string' is used as a query to obtain an object 
identifier based on contextual information that relates to the 
relationships between different objects and also to the 
relationships between different groups of objects. The objects 
to be searched for may also have more than one name, and the 
search may be based on any of these names and/or any other 
search direction or instruction. The location of a requested 
object the search function returns may comprise a path of 
related objects, the path leading the caller of the object to 
the requested object. Figure 1 shows an example of 
relationship paths between objects. 

More particularly, Figure 1 shows 6 objects having 
relationships with each other and several different paths 
between the related objects. For example, objects 'Q' , 1 B ' , 
♦W and 'Z' form a path. The location of the object >Z' can be 
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indicated by returning the path formed between *Q' and *Z',__ 
whereafter the object *Z' may be located and fetched by 
following the path from *Q' or any other object on the path to 
object *Z'. Figure 1 includes also a table for possibilities 
5 to locate object »C . The possibility of using different 

symbols in a search string will be discussed in more detail 
later in this description. 

Figure 2 is a simple example showing objects that are arranged 
10 in object groups in two different structures. In here an 

object group refers to a group of objects comprising an object 
and all descendants of that object. In this context the 
structures refer to a way to organise the different groups of 
objects in a "tree-like" arrangement based on the 
15 relationships or associations between the objects in each 

group and also the relationships between the different groups. 
Each object is linked to an appropriate structure by means of 
a structure link of the object. An example of the structure 
links is a structure link between an object A Pump2 ' and 
20 structure 1 that is indicated by arrow SL . 

As shown in Figure 2, an object may be placed i.e. reside in 
several different structures. More particularly, an object 
\Vessel' has been linked to two different structures 1 and 2. 
25 The object x Vessel' can be seen as placed in a first structure 

1 having a root 4 Process Areal' and also in a second structure 

2 having a main root x Building 3'. In the second structure the 
object 'Vessel' is placed below a sub-root x Room 361', i.e. is 
linked indirectly to the structure * Building 3' via an object 

30 'Room 361' . Although not shown, it should be appreciated that 
an object may also reside in multiple positions within one 
structure . 
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The structures may be based on different characteristics of 
the system. A structure may be based on the location of the 
real world entities that the objects represent, one could be 
based on control features and one on functional features and 
5 so on. 

It shall be appreciated that although Figure 1 shows only one 
name per object, each of the object may have several different 
names . 

10 

Each link or placement in the structures is represented by a 
structure link. Each link may be represented in an object as a 
structure link aspect. The different names that associate with 
objects may also be represented as aspects. Figure 3 shows 

15 four objects that are linked through aspects 4 Link 1' and 

'Link 2' . The aspects are placed in association with each of 
the objects. By means of the aspects the objects can be 
arranged in a hierarchical structure having one clear root and 
a clear set of children at each level in the hierarchy. That 

20 is, the aspects can be used to enable grouping of the objects 
and/or placement of the objects e.g. in the "tree-like" 
structured arrangement of Figure 2 . 

As was already mentioned, an object may be located based on 
25 information regarding the relationships between different 

objects and/or between different object groups. Information 
regarding these relationships can be based on information of 
the way the objects are linked by means of the structure link 
aspects . 

30 

According to the preferred embodiment a query for an object is 
based on a name string. A name string can be built up from a 
sequence of name items. The sequence of name items may contain 
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name aspects and a set of special symbols . The symbols can be 
used to describe where an object in the string can be found. 
The special symbols may be any appropriate symbols or 
combinations thereof, for example , x ..', or V, 

% / /' , and so on . 

To give an example of the use of the symbols, if the above 
"dot" symbols are used, the triple dotted periods in the name 
string can be dedicated to indicate any parent, the double ^ 
dotted periods can be dedicated to indicate the current parent 
and the simple dot the current structure link. These symbols 
can be interpreted so that a name string identifies an object 
and then uses the next token in the string to specialise a 
name of a child object in any structure unless a special 
15 symbol sets restrictions regarding the possible structures. 

The following example clarifies the use of the relationships 
between the objects and symbols between the object names. A 
name string V A B C ... D E' instructs the search function to 

20 find any set of objects that matches the given criteria. More 
particularly, the above string gives the following 
instructions: Find an object A that has a child B (possibly 
not direct) where B has a child C. Furthermore, the name C 
should have a parent (at any level) named D, which in turn 

25 should have a child E. It should be appreciated that in this 
example any structure transition may occur in any child or 
parent relation. 

The term x direct child' refers to a child that is a direct 
30 descendant of an object. The term any child refers to a child 
that may be a direct child or an indirect child (e.g. a direct 
child of any direct child) in the structure defining the 
relationships between the objects. It should be appreciated 
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.that the path of relationship is not restricted, to three level 
of objects (i.e. parent - 1 st child - 2 nd child), but may 
comprise more than three generations of relationships. 

5 The name string may be defined to bind the search e.g. to 
direct children only. The number of name aspects to be 
examined may also be reduced. For example, a name can be 
preceded by a definition in a square bracket that limits the 
scope of the aspect and/or names. In this case the string of/ 

10 object names could be written as 'A/ [relative name]B/C, 

wherein the relative name is the name category that needs to 
be examined. Another possibility to reduce the syntax or limit 
the search scope is to define what main categories (but 
nothing else) should be examined during the name look-up. In 

15 this approach the programmer may define those main categories 
that need to be searched. In the same manner it is possible to 
limit the set availability of structure transitions by 
explicitly specifying the structures that are to be examined. 
This can be implemented e.g. by defining the available 

20 structure transitions by appropriate symbols in the string. 

The next example is described with reference to Figures 2 and 
4. Figure 4 shows a plant 10. The plant 10 comprises three 
buildings Bl to B3 . In each building there are one or more 

25 pumps PI to P5 and valves VI to V4 . Figure 4 shows further 

three different process areas PA1 to PA3 . The process areas do 
not depend on the buildings, but depend rather on the 
functions of the process in an appropriate manner. Therefore 
e.g. process area PA1 includes pump PI and valve V4 from 

30 building B3 and pump P2 from building B2 . The process area PA1 
is also shown to include a valve Vn and a pump Pn that are not 
associated (at least directly) to any building. 
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The operation of the various components of the plant 10 is 
controlled by computer system 6. The computer system 6 may 
comprise any appropriate data processing facility, such as 
central processor unit (CPU) 7 of a PC and a database 9, such 
as a hard disk of a PC. The computer 6 may be provided with 
auxiliary devices such as a display 5, keyboard, a mouse and 
so on. The computer is enabled to communicate with the various 
elements of the plant 10 via a data connection 8, such as a 
local area network (LAN), other data network or a field bus . ,.- 
The skilled person is aware of various possibilities for the 
basic components of the computerised control system, and these 
will thus not be explained in more detail herein. 

A search string « Building3/Pump/AI2 ' is given to the search 
function of the computerised control system, wherein X AI2' is 
the name for an object representing the analogue input for the 
pump. The object * Building 3' (B3 in Figure 4) is located in 
the second structure 2. Thus the search function shall examine 
the location structure 2 to find the object ^Building 3'. 
However, as shown by Figure 4, the object name *Building3' " 
i.e. building B3 may contain a number of pumps, i.e. pumps Pi 
and P5. Therefore the search function may only receive 
indication that at least a pump is. located in the object name 
'Building3'. However, the pump can be any pump and thus the 
search function cannot define which one of the pumps is the 
correct one. Thus the input object name 'AI2' cannot be found 
solely based on the location structure or it may not be a 
unique name unless specified further through a context. 

To find the pump that has an analogue input named AI2 the 
control system shall also use information associated with the 
location structure or any other structure, for example the 
control structure or function structure to find an analogue 
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input with the name X AI2'. During the look-up possible names 
for the objects and the relationships between the objects and 
the object groups are analysed. An exemplifying procedure for 
this will be discussed in more detail below with reference to 
5 Figure 5. In the Figure 4 example the search function should 
analyse information regarding the relationships with the 
objects of the process areas PA1 and PA3 as well as objects 
that associate with building B3 and/or pumps in building B3 . 
The end result should be that the name AI2 associates with t£e 
10 pump PI in building B3 . 

The search function may be provided by the CPU 7 or other 
processor of the computer 6 of Figure 4 . The search function 
may respond a query signal by a computer data signal. The 

15 response signal may be generated at the search function such 
that it comprises information associated with the location of 
the requested object in the data storage means 9. The 
information is based on information regarding the name that 
associates with the requested object, relationships the object 

20 has with others of the objects, and the relationship groups. 
More particularly, the information returned by the search 
function may comprise at least one path of related objects 
such that the requested object is one of the objects on said 
at least one path of related objects. 

25 

The processor 7 of the computer may be adapted to provide the 
control function and to generate the query signal that is 
transported to the search function. The search function may 
also be provided by the processor 7. The search and control 
30 functions may also be provided by different processors or even 
by different computer entities that are provided with a 
communication connection enabling data signalling between the 
functions . 



15 



An algorithm that may be used to compute the set of related 
objects that in a predefined manner matches a given query 
string is as follows (see also Figure 5) : 

1. Preparation: Compute or select otherwise a set of available 
objects (and/or names of the objects) in the system. The 
available objects may obtained e.g. from an object 
directory service or alike. 

2. Preparation: Compute the number of relationships possible 
through each of the available in the system and assign the 
computed number of relationships as a cost to each of the 
selected objects. 

3 . Break the query string into tokens . 

4. Select an object having the smallest costs (i.e. the lowest 
number of relationships through it) . 

5. Examine the relationships of the selected object to select 
a path that matches the given query or paths that match the 
query . 

6. Return the selected one or more paths of related objects 
(or object names) . 

The available objects that are computed or otherwise selected 
fpr the analysis may be all possible objects in the system. 
According to an alternative embodiment the number of available 
objects is limited based on an appropriate criteria, e.g. by 
selecting only a limited amount of the available objects. The 
limitation of the objects to be analysed may be based on the 
information in the query. It is also possible to restrict the 
possible transitions between the structure groups. The search 
may also be limited e.g. to certain object categories defined 
in the name string. 
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The number of relationships each of the analyse 
with other objects is determined in the analysis. Based on the 
analysis an object is selected to be used as a starting point 
for further examination. If such a path of related object can 

5 be found based on the selected object that matches the query, 
the found path of related objects is returned as response to 
the query. If a matching path of related objects cannot be 
found based on the selected object, a message may be returned 
indication that the object was not found. Another object may.<- 

10 be selected whereafter the verifying process is repeated for 
this object. The further examination process loop may be run 
until a path of related objects is found that matches the 
search criteria. 

15 The object that is selected for the further examination may be 
an object with the lowest cost. The cost is determined for 
each analysed object and is based on the number of 
relationships each object has with other objects. The greater 
the number the greater the cost . 

20 

The cost function can be exemplified by the following simple 
example: If the relationships links between the selected 
objects A, B and C are A/B and B/C, this would mean that A has 
one relationship with other objects (with B) , B has two 

25 relationships (with A and C) and C has one relationship (with 
B) . In other words, A and C both have the lowest cost and B 
has the highest cost. Since both A and C have only one 
relationship with other objects, either of them could be 
chosen as the starting point. The selection between A and C 

30 may be based on any appropriate criteria. For example, a first 
object (i.e. A) in alphabetical order may be selected. 
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The name lookup may provide benefits especially in 
arrangements where a number of objects exist in a scope of 
objects and where each object may have a number of different 
names and structure links associated with it. 

It should be appreciated that whilst embodiments of the 
present invention have been described in relation to equipment 
in a processing plant, embodiments of the present invention 
are applicable to any field of data processing and to any 
types of objects. For example, the name look-up may be 
accomplished in different kind of data networks such as in 
local area networks (LAN) , intranet networks or open data 
networks such as the Internet. The embodiment may also be 
employed in systems employing distributed data processing, 
such as in distributed control programs or in control programs 
that execute distributed tasks. 

It is also noted herein that while the above describes 
exemplifying embodiments of the invention, there are several 
variations and modifications which may be made to the 
disclosed solution without departing from the scope of the 
present invention as defined in the appended claims. 
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Claims _ ....... 

1. A method in an object oriented computer system, wherein 
objects are enabled to have relationships with each other, the 
method comprising : 

receiving a query for a path of related objects, the 
query including information regarding an object and 
relationships associated with the object; 

analysing the different relationships associated with 
objects in the system to select objects based on said 
information included in the query; and 

based on said analysis, selecting a path of related 
objects, one of the objects in the path being the object 
indicated by the query. 

2. A method as claimed in claim 1, wherein the path of 
related objects extends between said one object and a root of 
a structure, said structure being arranged to organise objects 
relative to each other. 

3. A method as claimed in claim 1 or 2 , wherein the step of 
analysing comprises determination of the number of 
relationships each analysed object has with other objects. 

4. A method as claimed in claim 3, comprising selection of 
an object based on the analysis as a starting point for 
further examination . 

5. A method as claimed in claim 4, wherein an object with 
the lowest cost is selected for the further examination. 



6. A method as claimed in claim 5, wherein the cost is 
determined for each analysed object based on the number of 
relationships each object has with other objects. 

7 . A method as claimed in any preceding claim, wherein the 
query comprises a string of name items. 

8. A method as claimed in claim 7, wherein the string of 
name items is arranged in subsequent tokens, one token of t he- 
string indicating a name of one object and another token 
adjacent to the one token indicating a name of another object, 
said other object being a direct or indirect child or parent 
for said one object. 

9. A method as claimed in claims 4 to 8 , wherein the further 
examination comprises comparing relationships associated with 
the selected object to information in the query. 

10. A method as claimed in any of claims 7 to 9, wherein the 
string of name items is broken into tokens before the step of 
analysing . 

11. A method as claimed in any preceding claim, wherein the 
objects are placed in different structures, the structures 
associating the objects with different relationships 
categories . 

12. A method as claimed in claim 11, wherein the queried 
object and at least one other object indicated by the query 
are associated with different structures. 

13. A method as claimed in any of the preceding claims, 
wherein the objects are enabled to have more than one name. 
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14. A method as claimed in claim 13, wherein the different 
names for an object are indicated by aspects of the object. 

5 15. A method as claimed in any of claims 11 to 14, wherein 
an object is placed in more than one location in the 
structures . 

16. A method as claimed in any of claims 11 to 15, wherein 
10 the query contains information regarding at least one 

structure with which the object is expected to associate with. 

17. A method as claimed in any of claims 4 to 16, comprising 
the step of selecting a second object in the event that it is 

15 determined impossible to select the queried path of related 
objects based on said one selected object. 

18. A method as claimed in claim 17 when appended to any of 
claims 3 to 12 , wherein the step of selecting the second 

20 object comprises selection of an object with a different 
number of relationships than what said one object has. 

19. A method as claimed in any of claims 7 to 18, wherein the 
string of name items comprises at least one symbol between the 

25 name items. 

20. A method as claimed in claim 19, wherein the at least one 
symbol describes the relation between the objects the said at 
least one symbol associates with. 

30 

21. A method as claimed in any preceding claim, wherein the 
scope of the search performed in response to the query is 
limited by information in the query. 



22. A method as claimed in any preceding claim, wherein the 
scope of the search accomplished in response to the query is 
limited by defining limitations to the search scope. 

23. A method as claimed in any preceding claim, comprising 
step of selecting objects for the analysis of the 
relationships based on the information included in the query. 

24. A computer program comprising program code means for 
performing any of steps of claim 1 or any claim dependent 
thereto when the program is run on a computer. 

25. A computer program as claimed in claim 24, the program 
code means being stored in a computer readable medium. 

26. Use of a computer program as claimed in claim 24 or 25 
for finding an object in a computerised control system. 

27. A method in a computerised control system, comprising: 
associating objects representing real world entities to 

different relationship groups based on characteristics of the 
real world entities; 

initiating a search for an object by means of a query 
string containing information regarding the object; 

searching for the object based on a name associated with 
the object, relationships the object has with other objects 
and information that associates with relationship groups 
relevant for the searched object; and 

selecting a path of related objects that corresponds 
information in the query string and includes the searched 
obj ect . 



28. A data processing system comprising: 

a processor adapted for object oriented data processing; 

data storage means adapted for storing data objects, the 
objects being enabled to have relationships between each other 
and to be associated with different relationship groups; 

wherein the data processing system is adapted to provide 
the processor with an indication of the location of an object 
in the data storage means based on information regarding a 
name associated with the object, relationships the object has- 
with others of the objects, and the relationship groups. 

29. A data processing system as claimed in 28, wherein the 
indication is based on a path of related objects, the object 
being one object on the path of related objects. 

30. A data processing system as claimed in 28 or 19, wherein 
the processor is adapted to generate a query containing 
information regarding the object and at least one other object 
having a relationship with the object. 

31. A data processing system as claimed in any of claims 28 
to 30, wherein the processor is adapted to control operation 
of a system consisting of real world entities, the real world 
entities being represented by objects stored in the storage 
means . 

32. A computer data signal embodied for communication in a 
computerised system, the communication being associated with 
location of objects in data storage means of the system, and 
the objects being enabled to have relationships between each 
another and be associated with different relationship groups, 
wherein the data signal comprises information associated with 
a location of an object in the data storage means based on 



information regarding a name associated with the object, 
relationships the object has with others of the objects, and 
the relationship groups. 

33. A computer data signal as claimed in claim 32, wherein 
the information comprises at least one path of related 
objects, the object being one of the objects on said at least 
one path of related objects. 

34. A computer data signal as claimed in claim 32 or 33, 
wherein the computer data signal is generated at a search 
function of the computerised system to respond to a query 
signal, said query signal containing information regarding the 
object and at least one other object having a relationship 
with the object. 

35. A computer data signal as claimed in any of claims 32 to 
34, wherein the computerised system is adapted to control, 
based on the computer data signal, operation of a system 
consisting of real world entities, the real world entities 
being represented by objects stored in the storage means. 
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